

## Exercise sheet 6 – Processor architecture

#### Goals:

- Registers
- Addressing modes

### Exercise 6.1: Addressing modes (theoretical)

(a) Which addressing modes can be used for direct realisation of stack-operations on a CISC architecture (Freescale ColdFire, 32 bit architecture)? Are there any alternatives if those addressing modes are not available? Explain this by pushing the content of the D0 register to the stack; after that, pop the stack content to the D1 register. Hint: You may use some pseudo-code (assembler) to express your idea.

```
With appropriate addressing modes:

Push D0: MOVE.L D0, -(SP)
Pop D1: MOVE.L (SP)+, D1

Alternative:

Push D0: SUB #4, SP
MOVE.L D0, (SP)
```

**Proposal for solution:** Hint: MOVE.L for long word (or double word) (4 bytes, 32 bits)

- (b) How can a CISC architecture (Freescale ColdFire) support array-accesses? Find and use an appropriate addressing mode. Consider a 32 bit architecture. Use given values to describe your idea. Hint: You may write some pseudo-code (assembler) and draw a sketch.
  - access to x[i] (element i of array x, x contains integer data)
  - x starts at memory address 0x10000

MOVE.L (SP), D1

ADD #4, SP

• i = 20

Pop D1:

3

• use the registers A2 and D3

```
Proposal for solution:
int x[N]; // Array with N elements

// Prepare register content
MOVE.L 0x10000, A2
MOVE.L #20, D3

//Perform the array access (addressing mode only)
//C: x[i]
```

Prof. Dr. Florian Künzner





#### Exercise 6.2: Understanding a concrete Intel x86/64 instruction (theoretical)

- (a) Try to understand the **XCHG** (Exchange Register/Memory with Register) assembler instruction. Here are useful links:
  - https://www.felixcloutier.com/x86/xchg
  - https://www.amd.com/system/files/TechDocs/24594.pdf (page 360)
- (b) Which addressing modes does the **XCHG** instruction support?

**Proposal for solution:** It supports register to register and register to memory (and the other memory addressing alternatives).

#### Exercise 6.3: Use a concrete Intel x86/64 instruction (coding)

Given is the same endianness example ("Endianness with integer (coding)") as from the last exercise: A *big-endian* system program—the Java runtime environment—that transfers data via a file to a little-endian system C program.

Now, we want to use a single assembler instruction to perform the swap operation.

- (a) Update the CA exercises repository with git pull.
- (b) Change into the directory CA exercises/sheet 06 registers/Endianness/C LE asm swap

## Proposal for solution: cd CA\_exercises/sheet\_06\_registers/Endianness/C\_LE\_asm\_swap

(c) Inspect, build, and run the given C program.

# Proposal for solution:

make #build ./c\_le\_example #execute

(d) Analyse the output of the C program. What has happened? What could be the cause of this?



**Proposal for solution:** The C program is reading the content of *output.txt*, which was generated by the java-program. Because of the different endianness of Java (big endian) and C (little endian), the output of the C program is switched.

(e) Fix the problem in the C program, following the TODOs. Hint: use the XCHG reg/mem8, reg8 variant of the XCHG instruction to perform the swap.

```
Proposal for solution:
  #include <stdio.h> //fopen, ...
   #include <stdlib.h> //EXIT SUCCESS
   #include <stdint.h> //uint8 t, uint16 t
3
   int main(void) {
5
6
       uint16_t value = 0;
8
       FILE* file = NULL;
       file = fopen("../output.txt", "rb");
10
11
       if (file == NULL) {
12
           printf("Error opening output.txt\n");
13
           return EXIT_FAILURE;
14
       }
15
16
       fread(&value, sizeof(uint16_t), 1, file);
17
       fclose(file);
19
       printf("Read from output.txt -> : %2x\n", value);
20
21
       //Hint:
22
       // Syntax (Intel): Op-code dst, src;
23
       // Example (Intel): MOV EAX, 1; //moves a 1 into the EAX register
24
       //- with XCHG instruction you can exchange bytes within a register:
^{25}
       //- with AL you can use the AL register part (byte 0) of the (E)AX register
26
       //- with AH you can use the AH register part (byte 1) of the (E)AX register
27
       // - https://www.felixcloutier.com/x86/xchg
28
           - infos: AMD64 Architecture Programmer's Manual Volume 3:
29
       //
                     General Purpose and System Instructions: Page 396 (356)
30
       //
                     http://support.amd.com/TechDocs/24594.pdf
31
           - https://c9x.me/x86/html/file_module_x86_id_328.html
32
           - https://www.utd.hs-rm.de/infobuch2/Buch_Webseite/kap03/Assemblerbefehle.pdf
33
           - https://www.ibiblio.org/gferg/ldp/GCC-Inline-Assembly-HOWTO.html
34
       // volatile: let the compiler don't move the the ASM instructions around
       __asm__ volatile (
36
           "XCHG AL, AH;"
                              // swaps (exchange) the AL byte with the AH byte
37
            : "=a" (value)
                              // output: saves the AX register into the value
                              // can be considered as: MOV value, AX
39
            : "a" (value)
                              // input: loads the value into the AX register
40
                              // can be considered as: MOV AX, value
       );
42
43
       //print the fixed value
44
       printf("Converted to LE -> : %2x\n", value);
45
46
```

(f) Build and run the C program again. Is the problem now solved?

# Computer architecture Exercise sheet 6

SoSe 2022 Prof. Dr. Florian Künzner



# Proposal for solution:

make #build
c\_le\_example #execute